<!-- 边导航栏 -->
<template>
  <div :class="sideNavCls">
    <t-menu
      :class="menuCls"
      :theme="theme"
      :value="active"
      :collapsed="collapsed"
      :default-expanded="defaultExpanded"
    >
      <template #logo>
        <span
          v-if="showLogo && setting.mode.value === 'light'"
          :class="`${prefix}-side-nav-logo-wrapper`"
          @click="goHome"
        >
          <img
            v-if="!collapsed"
            class="logofull"
            src="@/assets/test-img/hiss_logo.png"
          />
          <img v-if="collapsed" class="logo" src="@/assets/test-img/logo.png" />
        </span>
        <span
          v-if="showLogo && setting.mode.value === 'black'"
          :class="`${prefix}-side-nav-logo-wrapper`"
          @click="goHome"
        >
          <img
            v-if="!collapsed"
            class="logofull"
            src="@/assets/logBlackTemFull.png"
          />
          <img v-if="collapsed" class="logo" src="@/assets/logBlackTem.png" />
        </span>
      </template>
      <menu-content :nav-data="menu" />
      <template #operations>
        <log-info />
      </template>
    </t-menu>
    <div
      :class="`${prefix}-side-nav-placeholder${collapsed ? '-hidden' : ''}`"
    ></div>
  </div>
</template>

<script setup lang="ts">
import { computed, onMounted } from 'vue'
import type { PropType } from 'vue'
import { useRouter } from 'vue-router'
import union from 'lodash/union'
import { storeToRefs } from 'pinia'
import LogInfo from '../components/LogInfo.vue'

import { useSettingStore } from '@/store'
import { prefix } from '@/config/global'
import type { MenuRoute } from '@/types/interface'
import { getActive, getRoutesExpanded } from '@/router'

// import AssetLogo from '@/assets/logo.svg?component'
// import AssetLogoFull from '@/assets/logo-full.svg?component'
import MenuContent from './MenuContent.vue'

const MIN_POINT = 992 - 1 // 992px

const router = useRouter()
const settingStore = useSettingStore()
const setting = storeToRefs(settingStore)

const props = defineProps({
  menu: {
    type: Array as PropType<MenuRoute[]>,
    default: () => []
  },
  showLogo: {
    type: Boolean as PropType<boolean>,
    default: true
  },
  isFixed: {
    type: Boolean as PropType<boolean>,
    default: true
  },
  layout: {
    type: String as PropType<string>,
    default: ''
  },
  headerHeight: {
    type: String as PropType<string>,
    default: '64px'
  },
  theme: {
    type: String as PropType<string>,
    default: 'light'
  },
  isCompact: {
    type: Boolean as PropType<boolean>,
    default: false
  }
})
// collapsed是侧边栏是否收起
const collapsed = computed(() => useSettingStore().isSidebarCompact)
// 是否选中
const active = computed(() => getActive())
// 展开的菜单
const defaultExpanded = computed(() => {
  const path = getActive()
  const parentPath = path.substring(0, path.lastIndexOf('/'))
  const expanded = getRoutesExpanded()
  return union(expanded, parentPath === '' ? [] : [parentPath])
})
// sideNavCls是计算侧边栏的样式
const sideNavCls = computed(() => {
  const { isCompact } = props
  return [
    `${prefix}-sidebar-layout`,
    {
      [`${prefix}-sidebar-compact`]: isCompact,
      modeStyle: setting.mode.value === 'black'
    }
  ]
})
// menuCls是计算侧边栏的样式
const menuCls = computed(() => {
  const { showLogo } = props
  return [
    `${prefix}-side-nav`,
    {
      [`${prefix}-side-nav-no-logo`]: !showLogo
    }
  ]
})
// autoCollapsed是自动收起
const autoCollapsed = () => {
  const isCompact = window.innerWidth <= MIN_POINT
  settingStore.updateConfig({
    isSidebarCompact: isCompact
  })
}

onMounted(() => {
  autoCollapsed()
  window.onresize = () => {
    autoCollapsed()
  }
})
// 返回首页
const goHome = () => {
  router.push('/dashboard/base')
}

// const getLogo = () => {
//   if (collapsed.value) return AssetLogo
//   return AssetLogoFull
// }
// 返回登录页
const handleLogout = () => {
  router.push({
    path: '/login',
    query: { redirect: encodeURIComponent(router.currentRoute.value.fullPath) }
  })
}
</script>

<style lang="less" scoped>
:deep(.t-default-menu .t-menu__operations:not(:empty)) {
  padding: 0;
  border-top: 0;
}
:deep(.t-default-menu__inner .t-menu__logo:not(:empty)) {
  border-bottom: 0;
  margin-top: 31px;
}
.logofull {
  width: 99px;
  height: 69px;
  margin-left: -10px;
}
.logo {
  width: 24px;
  height: 27px;
}
.t-default-menu__inner .t-menu--scroll {
  padding-top: 24px;
}
</style>
